package org.example.StacksAndQueues;

import java.util.LinkedList;
import java.util.Queue;

class MyStack {
    //用队列实现栈

    //请你仅使用两个队列实现一个后入先出（LIFO）的栈，并支持普通栈的全部四种操作（push、top、pop 和 empty）。
    //实现 MyStack 类：
    //void push(int x) 将元素 x 压入栈顶。
    //int pop() 移除并返回栈顶元素。
    //int top() 返回栈顶元素。
    //boolean empty() 如果栈是空的，返回 true ；否则，返回 false 。
    //注意：
    //你只能使用队列的基本操作 —— 也就是 push to back、peek/pop from front、size 和 is empty 这些操作。
    //你所使用的语言也许不支持队列。 你可以使用 list （列表）或者 deque（双端队列）来模拟一个队列 , 只要是标准的队列操作即可
    Queue<Integer> queueHost;
    Queue<Integer> queueAssist;

    public MyStack() {
        queueHost = new LinkedList<>();
        queueAssist = new LinkedList<>();
    }

    public void push(int x) {
        queueHost.add(x);
    }

    public int pop() {
        insertQueueAssist();
        Integer value = queueHost.remove();
        insertQueueHost();
        return value;
    }

    public int top() {
        int value = pop();
        push(value);
        return value;
    }

    public boolean empty() {
        return queueHost.isEmpty();
    }
    public void insertQueueAssist(){
        while(queueHost.size()>1){
            queueAssist.add(queueHost.remove());
        }
    }
    public void insertQueueHost(){
        while (!queueAssist.isEmpty()){
            queueHost.add(queueAssist.remove());
        }
    }
}
